home *** CD-ROM | disk | FTP | other *** search
/ PD Collection CD 1 / PD Collection CD 1.iso / textual / pdftops / xpdf / c++ / OutputDev < prev    next >
Text File  |  1996-06-08  |  1KB  |  40 lines

  1. //========================================================================
  2. //
  3. // OutputDev.cc
  4. //
  5. // Copyright 1996 Derek B. Noonburg
  6. //
  7. //========================================================================
  8.  
  9. #ifdef __GNUC__
  10. //#pragma implementation
  11. #endif
  12.  
  13. #include <stddef.h>
  14. #include "OutputDev.h"
  15.  
  16. void OutputDev::setCTM(double *ctm1) {
  17.   int i;
  18.   double det;
  19.  
  20.   for (i = 0; i < 6; ++i)
  21.     ctm[i] = ctm1[i];
  22.   det = 1 / (ctm[0] * ctm[3] - ctm[1] * ctm[2]);
  23.   ictm[0] = ctm[3] * det;
  24.   ictm[1] = -ctm[1] * det;
  25.   ictm[2] = -ctm[2] * det;
  26.   ictm[3] = ctm[0] * det;
  27.   ictm[4] = (ctm[2] * ctm[5] - ctm[3] * ctm[4]) * det;
  28.   ictm[5] = (ctm[1] * ctm[4] - ctm[0] * ctm[5]) * det;
  29. }
  30.  
  31. void OutputDev::cvtDevToUser(int dx, int dy, double *ux, double *uy) {
  32.   *ux = ictm[0] * dx + ictm[2] * dy + ictm[4];
  33.   *uy = ictm[1] * dx + ictm[3] * dy + ictm[5];
  34. }
  35.  
  36. void OutputDev::cvtUserToDev(double ux, double uy, int *dx, int *dy) {
  37.   *dx = (int)(ctm[0] * ux + ctm[2] * uy + ctm[4] + 0.5);
  38.   *dy = (int)(ctm[1] * ux + ctm[3] * uy + ctm[5] + 0.5);
  39. }
  40.